package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import org.aspectj.weaver.ast.Var;
import org.springframework.beans.NotWritablePropertyException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    /**
     * =========================================================新增数据============================================
     */
    @PostMapping("/saveData")
    public AjaxResult saveData(@RequestBody Review review) {
       return toAjax(reviewService.saveData(review));
    }

    /**
     * =========================================================删除数据=============================================
     */
    @DeleteMapping("/remove/{id}")
    public AjaxResult remove(@PathVariable int id) {
        return toAjax(reviewService.remove(id));
    }

    /**=========================================================修改数据=============================================*/
    @PostMapping("/update")
    public AjaxResult update(@RequestBody Review review) {
        return toAjax(reviewService.update(review));
    }

    /**
     * =========================================================查询数据=============================================
     */
    @GetMapping("/getById")
    public AjaxResult getById(int id) {
        return AjaxResult.success("查询成功",reviewService.getById(id));
    }
    @GetMapping("/getDataByPage")
    public TableDataInfo getDataByPage(Integer pageNum,Integer pageSize) {
        System.out.println(pageNum+"---------"+pageSize);
        //TableDataInfo tableDataInfo=new TableDataInfo();
       List<Review> list=reviewService.getDataByPage(pageNum,pageSize);
        int toatl = (int) reviewService.getToatl();
      /* if (list!=null){
           tableDataInfo.setCode(200);
           tableDataInfo.setTotal(reviewService.getToatl());
           tableDataInfo.setMsg("查询成功");
           tableDataInfo.setRows(list);
       }
       else {
           tableDataInfo.setCode(500);
           tableDataInfo.setMsg("查询失败");

       }*/

        return new TableDataInfo(list,toatl);
    }


}